--- file_format: mystnb kernelspec: name: python3 --- (sec-qblox-how-to-configure)= # Usage of the backend Configuring the backend is done by specifying a Python dictionary (or loading it from a JSON file) that describes your experimental setup. An example of such a hardware configuration is shown below. The entry {code}`"backend": "quantify_scheduler.backends.qblox_backend.hardware_compile"` specifies to the scheduler that we are using the Qblox backend (specifically the {func}`~quantify_scheduler.backends.qblox_backend.hardware_compile` function). Two variants of the same hardware configuration are shown: - The current old-style unvalidated json/dict hardware configuration (see {ref}`sec-qblox-cluster`). - The new {class}`~.backends.types.common.HardwareCompilationConfig` variant that adds validation of the contents and divides into `"hardware_description"`, `"hardware_options"` and `"connectivity"` (see {ref}`Cluster (HardwareCompilationConfig) `, and the {ref}`sec-hardware-compilation-config` section of the User guide). ```{code-cell} ipython3 --- tags: [hide-cell] mystnb: code_prompt_show: "Example hardware configuration" remove_code_source: true --- import inspect import json import os from pathlib import Path import quantify_scheduler.schemas.examples as es from quantify_scheduler.backends.graph_compilation import SerialCompilationConfig from quantify_scheduler.backends.qblox import helpers from quantify_scheduler.backends.qblox_backend import QbloxHardwareCompilationConfig esp = inspect.getfile(es) cfg_f = Path(esp).parent / "qblox_hardware_compilation_config.json" with open(cfg_f, "r") as file: qblox_hardware_compilation_config = json.load(file) compilation_config = SerialCompilationConfig( name="Qblox compiler", hardware_compilation_config=QbloxHardwareCompilationConfig.parse_obj( qblox_hardware_compilation_config ), compilation_passes=[], ) old_style_hardware_config = helpers.generate_hardware_config( compilation_config=compilation_config ) # Sort and then reorder such that latency_corrections and distortion_corrections are on top old_style_hardware_config = json.loads( json.dumps(old_style_hardware_config, sort_keys=True) ) backend = old_style_hardware_config.pop("backend") latency_corrections = old_style_hardware_config.pop("latency_corrections") distortion_corrections = old_style_hardware_config.pop("distortion_corrections") old_style_hardware_config = { **{ "backend": backend, "latency_corrections": latency_corrections, "distortion_corrections": distortion_corrections, }, **old_style_hardware_config, } print(json.dumps(old_style_hardware_config, indent=4, sort_keys=False)) ``` ```{code-cell} ipython3 --- tags: [hide-cell] mystnb: code_prompt_show: "Example hardware configuration (HardwareCompilationConfig)" remove_code_source: true --- import json import os, inspect from pathlib import Path import quantify_scheduler.schemas.examples as es esp = inspect.getfile(es) cfg_f = Path(esp).parent / "qblox_hardware_compilation_config.json" with open(cfg_f, "r") as f: qblox_hardware_compilation_config = json.load(f) print(json.dumps(qblox_hardware_compilation_config, indent=4, sort_keys=False)) # Do not sort to retain the order as in the file ```